<template>
  <el-dialog v-model="visible" :title="!dataForm.id ? '新增' : '修改'" :close-on-click-modal="false" draggable>
    <el-form ref="dataFormRef" :model="dataForm" :rules="dataRules" label-width="120px" @keyup.enter="submitHandle()">
      <el-form-item prop="communityName" label="社区名称">
        <el-input v-model="dataForm.communityName" placeholder="社区名称"></el-input>
      </el-form-item>
      <el-form-item prop="communityCode" label="社区编码">
        <el-input v-model="dataForm.communityCode" placeholder="社区编码"></el-input>
      </el-form-item>
      <el-form-item prop="orgId" v-if="userStore.user.username == 'admin'" label="所属机构">
        <el-tree-select
            v-model="dataForm.orgId"
            :data="orgList"
            value-key="id"
            check-strictly
            :render-after-expand="false"
            :props="{ label: 'name', children: 'children' }"
            style="width: 100%"
            clearable
        />
      </el-form-item>
      <el-form-item prop="communityAddress" label="详细地址">
        <el-input v-model="dataForm.communityAddress" placeholder="详细地址"></el-input>
      </el-form-item>
      <el-form-item prop="communityLongitude" label="经度">
        <el-input v-model="dataForm.communityLongitude" placeholder="经度"></el-input>
      </el-form-item>
      <el-form-item prop="communityLatitude" label="纬度">
        <el-input v-model="dataForm.communityLatitude" placeholder="纬度"></el-input>
      </el-form-item>

    </el-form>
    <template #footer>
      <el-button @click="visible = false">取消</el-button>
      <el-button type="primary" @click="submitHandle()">确定</el-button>
    </template>
  </el-dialog>
</template>

<script setup lang="ts">
import { reactive, ref } from 'vue'
import { ElMessage } from 'element-plus/es'
import { communityApi, communitySubmitApi } from '@/api/new/community'
import {useOrgListApi} from "@/api/sys/orgs";
import {useUserStore} from "@/store/modules/user";



const emit = defineEmits(['refreshDataList'])

const userStore = useUserStore()

const visible = ref(false)
const menuListTree = ref()
const dataFormRef = ref()
const orgList = ref([])

const dataForm = reactive({
  id: '',
  communityName: '',
  communityCode: '',
  communityAddress: '',
  communityLongitude: '',
  communityLatitude: '',
  orgId: undefined
})

const init = async (id?: number) => {
  visible.value = true
  dataForm.id = ''

  // 重置表单数据
  if (dataFormRef.value) {
    dataFormRef.value.resetFields()
  }
  if (menuListTree.value) {
    menuListTree.value.setCheckedKeys([])
  }

  console.log(id)

  getOrgList()

  // id 存在则为修改
  if (id) {
    getCommunity(id)
  }
}



// 获取信息
const getCommunity = (id: number) => {
  communityApi(id).then(res => {
    Object.assign(dataForm, res.data)
  })
}

// 获取机构列表
const getOrgList = () => {
  return useOrgListApi().then(res => {
    orgList.value = res.data
  })
}

const dataRules = ref({
  communityName: [{ required: true, message: '必填项不能为空', trigger: 'blur' }],
  communityCode: [{ required: true, message: '必填项不能为空', trigger: 'blur' }],
})

// 表单提交
const submitHandle = () => {
  dataFormRef.value.validate((valid: boolean) => {
    if (!valid) {
      return false
    }
    // dataForm.menuIdList = [...menuListTree.value.getHalfCheckedKeys(), ...menuListTree.value.getCheckedKeys()]

    communitySubmitApi(dataForm).then(() => {
      ElMessage.success({
        message: '操作成功',
        duration: 500,
        onClose: () => {
          visible.value = false
          emit('refreshDataList')
        }
      })
    })
  })
}

defineExpose({
  init
})

</script>
